home *** CD-ROM | disk | FTP | other *** search
/ Ham Radio 2000 / Ham Radio 2000.iso / ham2000 / misc / dspice0s / putnod.c < prev    next >
C/C++ Source or Header  |  1992-11-21  |  4KB  |  131 lines

  1. /* putnod.f -- translated by f2c (version of 3 February 1990  3:36:42).
  2.    You must link the resulting object file with the libraries:
  3.     -lF77 -lI77 -lm -lc   (in that order)
  4. */
  5.  
  6. #include "f2c.h"
  7.  
  8. /* Common Block Declarations */
  9.  
  10. struct {
  11.     integer ielmnt, isbckt, nsbckt, iunsat, nunsat, itemps, numtem, isens, 
  12.         nsens, ifour, nfour, ifield, icode, idelim, icolum, insize, 
  13.         junode, lsbkpt, numbkp, iorder, jmnode, iur, iuc, ilc, ilr, 
  14.         numoff, isr, nmoffc, iseq, iseq1, neqn, nodevs, ndiag, iswap, 
  15.         iequa, macins, lvnim1, lx0, lvn, lynl, lyu, lyl, lx1, lx2, lx3, 
  16.         lx4, lx5, lx6, lx7, ld0, ld1, ltd, imynl, imvn, lcvn, nsnod, 
  17.         nsmat, nsval, icnod, icmat, icval, loutpt, lpol, lzer, irswpf, 
  18.         irswpr, icswpf, icswpr, irpt, jcpt, irowno, jcolno, nttbr, nttar, 
  19.         lvntmp;
  20. } tabinf_;
  21.  
  22. #define tabinf_1 tabinf_
  23.  
  24. struct {
  25.     integer locate[50], jelcnt[50], nunods, ncnods, numnod, nstop, nut, nlt, 
  26.         nxtrm, ndist, ntlin, ibr, numvs, numalt, numcyc;
  27. } cirdat_;
  28.  
  29. #define cirdat_1 cirdat_
  30.  
  31. struct {
  32.     doublereal value[200000];
  33. } blank_;
  34.  
  35. #define blank_1 blank_
  36.  
  37. /* Table of constant values */
  38.  
  39. static integer c__1 = 1;
  40.  
  41. /*<       subroutine putnod(node) >*/
  42. /* Subroutine */ int putnod_(node)
  43. integer *node;
  44. {
  45.     /* System generated locals */
  46.     integer i_1;
  47.  
  48.     /* Local variables */
  49.     static integer jknt;
  50.     extern /* Subroutine */ int copy4_();
  51.     static integer k;
  52. #define nodplc ((integer *)&blank_1)
  53. #define cvalue ((complex *)&blank_1)
  54.     extern /* Subroutine */ int extmem_();
  55.  
  56. /*<       implicit double precision (a-h,o-z) >*/
  57.  
  58. /*     this routine adds 'node' to the list of user input nodes in table 
  59. */
  60. /* junode. */
  61.  
  62. /* spice version 2g.6  sccsid=tabinf 3/15/83 */
  63. /*<       common /tabinf/ ielmnt,isbckt,nsbckt,iunsat,nunsat,itemps,numtem, >*/
  64. /*<      1   isens,nsens,ifour,nfour,ifield,icode,idelim,icolum,insize, >*/
  65. /*<      2   junode,lsbkpt,numbkp,iorder,jmnode,iur,iuc,ilc,ilr,numoff,isr, >*/
  66. /*<      3   nmoffc,iseq,iseq1,neqn,nodevs,ndiag,iswap,iequa,macins,lvnim1, >*/
  67. /*<      4   lx0,lvn,lynl,lyu,lyl,lx1,lx2,lx3,lx4,lx5,lx6,lx7,ld0,ld1,ltd, >*/
  68. /*<      5   imynl,imvn,lcvn,nsnod,nsmat,nsval,icnod,icmat,icval, >*/
  69. /*<      6   loutpt,lpol,lzer,irswpf,irswpr,icswpf,icswpr,irpt,jcpt, >*/
  70. /*<      7   irowno,jcolno,nttbr,nttar,lvntmp >*/
  71. /* spice version 2g.6  sccsid=cirdat 3/15/83 */
  72. /*<       common /cirdat/ locate(50),jelcnt(50),nunods,ncnods,numnod,nstop, >*/
  73. /*<      1   nut,nlt,nxtrm,ndist,ntlin,ibr,numvs,numalt,numcyc >*/
  74. /* spice version 2g.6  sccsid=blank 3/15/83 */
  75. /*<       common /blank/ value(200000) >*/
  76. /*<       integer nodplc(64) >*/
  77. /*<       complex cvalue(32) >*/
  78. /*<       equivalence (value(1),nodplc(1),cvalue(1)) >*/
  79.  
  80.  
  81. /*<       jknt=0 >*/
  82.     jknt = 0;
  83. /*<    10 jknt=jknt+1 >*/
  84. L10:
  85.     ++jknt;
  86. /*<       if (jknt.gt.nunods) go to 20 >*/
  87.     if (jknt > cirdat_1.nunods) {
  88.     goto L20;
  89.     }
  90. /*<       if (node-nodplc(junode+jknt)) 20,100,10 >*/
  91.     if ((i_1 = *node - nodplc[tabinf_1.junode + jknt - 1]) < 0) {
  92.     goto L20;
  93.     } else if (i_1 == 0) {
  94.     goto L100;
  95.     } else {
  96.     goto L10;
  97.     }
  98. /*<    20 k=nunods+1 >*/
  99. L20:
  100.     k = cirdat_1.nunods + 1;
  101. /*<       call extmem(junode,1) >*/
  102.     extmem_(&tabinf_1.junode, &c__1);
  103. /*<       if (k.le.jknt) go to 30 >*/
  104.     if (k <= jknt) {
  105.     goto L30;
  106.     }
  107. /*<       call copy4(nodplc(junode+jknt),nodplc(junode+jknt+1),k-jknt) >*/
  108.     i_1 = k - jknt;
  109.     copy4_(&nodplc[tabinf_1.junode + jknt - 1], &nodplc[tabinf_1.junode + 
  110.         jknt], &i_1);
  111. /*<       k=jknt >*/
  112.     k = jknt;
  113. /*<    30 nodplc(junode+k)=node >*/
  114. L30:
  115.     nodplc[tabinf_1.junode + k - 1] = *node;
  116. /*<       nunods=nunods+1 >*/
  117.     ++cirdat_1.nunods;
  118.  
  119. /*  finished */
  120.  
  121. /*<   100 return >*/
  122. L100:
  123.     return 0;
  124. /*<       end >*/
  125. } /* putnod_ */
  126.  
  127. #undef cvalue
  128. #undef nodplc
  129.  
  130.  
  131.